/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package bpmlab.shift.dao;

import bpmlab.shift.dao.service.GenericDAO;
import bpmlab.shift.dao.service.UsuarioDAO;
import bpmlab.shift.entity.Usuario;
import java.util.List;
import javax.persistence.EntityManager;

/**
 *
 * @author Mikael Lima
 */
public class UsuarioDAOJpa implements UsuarioDAO {

    private final GenericDAO<Usuario> dao = DAOFactory.criarGenericDAO(Usuario.class);

    @Override
    public void salvar(Usuario o) throws DAOException {
        dao.salvar(o);
    }

    @Override
    public void excluir(Usuario o) throws DAOException {
        dao.excluir(o);
    }

    @Override
    public Usuario obter(Object id) {
        return dao.obter(id);
    }

    @Override
    public List<Usuario> obterTodos() {
        return dao.obterTodos();
    }

    @Override
    public Usuario obterPorLogin(String login) {
        EntityManager em = JpaUtil.getEntityManager();
        String jpql = "select u from Usuario u where u.login = :login";
        return em.createQuery(jpql, Usuario.class)
                .setParameter("login", login)
                .getSingleResult();
    }

    @Override
    public List<Usuario> obterTodosComPapeis() {
        EntityManager em = JpaUtil.getEntityManager();
        String jpql = "select distinct u from Usuario u left join fetch u.papeis";
        return em.createQuery(jpql, Usuario.class)
                .getResultList();
    }

}
